-
Notifications
You must be signed in to change notification settings - Fork 82
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[EI-461] Index royalty in royalty tables #381
Conversation
); | ||
|
||
CREATE TABLE current_token_royalty ( | ||
token_data_id VARCHAR(66) NOT NULL, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I forgot why we don't have a unique id for the token.. but using hash value alone as primary key can be dangerous since collision may happen.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a good point. Including creator_address
in the primary key can help with collision. Let me add that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@larry-aptos explained to me how collision can happen, but i forgot the reason cc @grao1991
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hash id is not guaranteed to be unique. It may be a problem when two different entities have the same hash value.
it seems ahash uses 64bit and considering 10million items, we get this
If we consider the number of items(i.e. token) can go up to 10m, we should take the probability of collision into account and add a field to make pk unique, otherwise, we should be fine.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
wait what? these hashes aren't randomly generated though so can collision still happen? I don't think that creator address is necessary b/c it's part of the hash.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also the tokens tables don't have this level of protection so we'll end up with issues anyway.
rust/processor/migrations/2024-05-21-221101_add_royalty_v1/up.sql
Outdated
Show resolved
Hide resolved
8b38773
to
bbea445
Compare
rust/processor/migrations/2024-05-21-221101_add_royalty_v1/up.sql
Outdated
Show resolved
Hide resolved
New changes lgtm. Thanks @bowenyang007 ! |
32c927e
to
b498580
Compare
Description
current_token_royalty_v1
table (note that v2 royalty requires collection id which isn't currently supported in this PR)token_v2_processor
Backfill
Testnet: 0
Mainnet: 0
Test Plan
Mainnet transaction 613858541